var editObj=null,ptable=null,treeGrid=null,tableId='treeTable',layer=null;
layui.use(['jquery','treeGrid','layer'], function(){
    var $=layui.jquery;
    treeGrid = layui.treeGrid;//很重要
    layer=layui.layer;

    ptable=treeGrid.render({
        id:tableId
        ,elem: '#'+tableId
        ,url:'/dictionary/list'
        ,cellMinWidth: 100
        ,idField:'id'//必須字段
        ,treeId:'id'//树形id字段名称
        ,treeUpId:'parentId'//树形父id字段名称
        ,treeShowName:'name'//以树形式显示的字段
        ,heightRemove:[".dHead",10]//不计算的高度,表格设定的是固定高度，此项不生效
        ,height:'100%'
        ,isFilter:false
        ,iconOpen:true//是否显示图标【默认显示】
        ,isOpenDefault:true//节点默认是展开还是折叠【默认展开】
        ,loading:true
        ,method:'post'
        ,limit : 20
        ,isPage:false
        ,cols: [[
            {type:'numbers'}
            ,{type:'checkbox',sort:true}
            ,{field:'name', width:200, title: '名称'/*,edit:'text'*/,sort:true}
            ,{field:'type', title: '字段类型'/*,edit:'text',sort:true*/}
            ,{field:'id', title: 'id'/*,sort:true*/}
            ,{field:'value', title: '业务代码',sort:true}
            ,{field:'parentId', title: 'pid'/*,sort:true*/}
            ,{field:'description', title: '备注'}
            ,{Width:100,title: '操作', align:'center'/*,templet: '#tableBar'*/
                ,templet: function(d){
                    var html='';
                    var addBtn='<a class="layui-btn layui-btn-xs" lay-event="edit">修改属性</a>';
                    var delBtn='<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>';
                    return addBtn+delBtn;
                }
            }
        ]]
        ,parseData:function (res) {//数据加载后回调
            return res;
        }
        ,onClickRow:function (index, o) {
            /*console.log(index,o,"单击！");*/
        }
        ,onDblClickRow:function (index, o) {
            /*console.log(index,o,"双击");*/
        }
    });

    //关闭数据
    /*treeGrid.treeOpenAll(tableId,false);*/

    //查询
    /*$(".search_btn").on("click",function(){
        var searchKey = $(".searchVal").val();
        if(searchKey != ''){
            option.url = '/dictionary/query';
            option.where = {name: searchKey};
            treeGrid.render(option);
        }else{
            layer.msg("请输入搜索的内容");
        }
    });*/

    treeGrid.on('tool('+tableId+')',function (obj) {
        if(obj.event === 'del'){//删除行
            del(obj);
        }else if(obj.event==="edit"){//添加行
            var index = layui.layer.open({
                title : "修改字典信息",
                type : 2,
                content : "dictionaryEdit.html?id=" + obj.data.id,
                area: ['100%',$(document).height() - 30 + 'px'],
                success : function(){
                    setTimeout(function(){
                        layui.layer.tips('点击此处返回字典信息列表', '.layui-layer-setwin .layui-layer-close', {
                            tips: 3
                        });
                    },500);
                }
            });
            layui.layer.full(index);
            //改变窗口大小时，重置弹窗的宽高，防止超出可视区域（如F12调出debug的操作）
            $(window).on("resize",function(){
                layui.layer.full(index);
            });
        }
    });

    //添加顶级字典数据
    $(".addBtn").click(function(){
        var index = layui.layer.open({
            title : "添加字典数据",
            type : 2,
            content : "dictionaryAdd.html",
            area: ['100%',$(document).height() - 30 + 'px'],
            success : function(layero, index){
                var body = layui.layer.getChildFrame('body', index);
                setTimeout(function(){
                    layui.layer.tips('点击此处返回用户列表', '.layui-layer-setwin .layui-layer-close', {
                        tips: 3
                    });
                },500)
            }
        })
        layui.layer.full(index);
        //改变窗口大小时，重置弹窗的宽高，防止超出可视区域（如F12调出debug的操作）
        $(window).on("resize",function(){
            layui.layer.full(index);
        });
    });

    function del(obj) {
        layer.confirm("你确定删除数据吗？如果存在下级节点则一并删除，此操作不能撤销！", {icon: 3, title:'提示'},
            function(index){//确定回调
                layer.close(index);
                $.get("/dictionary/delete?id=" + obj.data.id,function(data){
                    if (data.code == 200) {
                        layer.msg("删除成功！");
                    } else {
                        layer.msg("删除失败，请重试！");
                    }
                    location.reload();
                    layer.close(index);
                });
            },function (index) {//取消回调
                layer.close(index);
            }
        );
    }

});



var i=1000;
//添加
function add(pObj) {
    var pdata=pObj?pObj.data:null;
    var param={};
    param.name='水果'+Math.random();
    param.id=++i;
    param.pId=pdata?pdata.id:null;
    treeGrid.addRow(tableId,pdata?pdata[treeGrid.config.indexName]+1:0,param);
}

function print() {
    console.log(treeGrid.cache[tableId]);
    var loadIndex=layer.msg("对象已打印，按F12，在控制台查看！", {
        time:3000
        ,offset: 'auto'//顶部
        ,shade: 0
    });
}